<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            padding: 0;
            margin: 0;
        }
        
        table {
            border: 1px solid black;
            width: 300px;
            border-collapse: collapse;
            border-spacing: 0;
            /* 设置相邻单元边框间的距离，仅用于边框分离模式 */
        }
        
        th,
        td {
            border: 1px solid #d0d0d0;
            color: #404060;
            padding: 10px;
        }
        
        th {
            background-color: #09c;
            font: bold 16px "微软雅黑";
            color: #fff;
        }
        
        td {
            font: 14px "微软雅黑";
        }
        
        tbody tr {
            background-color: #f0f0f0;
        }
    </style>
</head>

<body>
    <!-- 全选和取消全选的做法：让下面所有复选框的checked属性（选中状态）跟随 全选按钮即可 -->
    <div class="wrap">
        <table>
            <thead>
                <tr>
                    <th>
                        <input type="checkbox" id="bt">
                    </th>
                    <th>商品</th>
                    <th>价钱</th>
                </tr>
            </thead>
            <tbody id="tb">
                <tr>
                    <td>
                        <input type="checkbox">
                    </td>
                    <td>iphone8</td>
                    <td>8000</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox">
                    </td>
                    <td>ipad Pro</td>
                    <td>5000</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox">
                    </td>
                    <td>ipad Air</td>
                    <td>2000</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox">
                    </td>
                    <td>Apple Watch</td>
                    <td>2000</td>
                </tr>
            </tbody>
        </table>
    </div>
    <script>
        //1.获取元素
        var bt = document.getElementById('bt'); //全选按钮
        var tb = document.getElementById('tb').getElementsByTagName('input'); //下面所有复选框
        //2.注册事件
        bt.onclick = function() {
                // this.checked可以得到当前复选框的选中状态，如果是true就是选中，如果是false就是不选中
                for (var i = 0; i < tb.length; i++) {
                    tb[i].checked = this.checked;
                }
            }
            //下面复选按钮影响上面的
        for (var i = 0; i < tb.length; i++) {
            tb[i].onclick = function() {
                // flag控制全选按钮是否被选中
                var flag = true;
                //每次点击下面的复选框都要检查下面4个小按钮是否全被选中
                for (var i = 0; i < tb.length; i++) {
                    if (!tb[i].checked) { //某一个按钮没有被选中   tb[i].checked点击之后都是true
                        flag = false; //最上面复选框不选中
                        //跳出整个循环 因为一个只要没有被选中，那最上面的复选框必定不会被选中 即flag必定为false
                        break; //可提高执行效率
                    }
                }
                bt.checked = flag;
            }
        }
    </script>
</body>

</html>